package coba.mailing.mail;

import java.io.IOException;
import java.sql.Connection;
import java.sql.SQLException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;

import org.apache.commons.mail.EmailException;
import org.apache.commons.mail.HtmlEmail;

import coba.mailing.body.Body9;
import coba.mailing.jdbc.ConnectionFactory;
import coba.mailing.model.Solicitud;
import coba.mailing.procedure.AddAllCC;
import coba.mailing.properties.MainProperties;
import coba.mailing.query.FindSolicitudCanceladasBetween;

public class Mail9 {

	public static void sendAll() throws ClassNotFoundException, IOException, SQLException, EmailException {
		Connection con = ConnectionFactory.getConnection();

		List<Solicitud> listSolicitud = FindSolicitudCanceladasBetween.find(con);

		for (Solicitud solicitud : listSolicitud) {
			try {
				if (solicitud.getContactoEmail() != null && !solicitud.getContactoEmail().trim().equals("")) {
					Date fechaATenerEnCuenta;

					if (solicitud.getFechaBaja() != null)
						fechaATenerEnCuenta = solicitud.getFechaItinerario();
					else
						fechaATenerEnCuenta = solicitud.getFechaPreviaItinerario();

					if (fechaATenerEnCuenta != null)
						send(solicitud);
				}
			}
			catch (Exception e) {
				e.printStackTrace();
			}

		}

		con.close();
	}

	public static void send(Solicitud solicitud) throws EmailException, IOException {
		MainProperties mainProperties = MainProperties.getInstance();

		HtmlEmail email = new HtmlEmail();

		email.setCharset("utf-8");
		email.setHostName(mainProperties.getProperty("smtpServer"));
		email.setSmtpPort(Integer.valueOf(mainProperties.getProperty("smtpPort")));
		email.addTo(solicitud.getContactoEmail());

		AddAllCC.addAllCC(email, mainProperties.getProperty("mail9Ccs"));

		email.setFrom(mainProperties.getProperty("fromMail"), mainProperties.getProperty("fromName"));

		Date fechaATenerEnCuenta = null;

		if (solicitud.getFechaBaja() != null)
			fechaATenerEnCuenta = solicitud.getFechaItinerario();
		else
			fechaATenerEnCuenta = solicitud.getFechaPreviaItinerario();

		email.setSubject("ConociendoBA - CANCELACIÓN VISITA " +
				new SimpleDateFormat("dd/MM/yyyy").format(fechaATenerEnCuenta));

		String cid = email.embed(ClassLoader.getSystemClassLoader().getResource("coba-mail-footer.jpg"), "Conociendo footer");

		email.setHtmlMsg(Body9.get(cid, solicitud));

		email.send();
	}

}
